(19) 



J 




(12) 



(43) Date of publication: 

25.06.1997 Bulletin 1997/26 

(21) Application number: 95480182.5 

(22) Date of filing: 20.1 2,1 995 



Europaisches Patentamt 
European Patent Office 
Office europ6en des brevets (1 1 ) EP 0 781 068 A1 

EUROPEAN PATENT APPLICATION 

(51) Int. Cl«: H04Q 11/04. H04L 12/56 



(84) Designated Contracting States: 


* Gaiand, Claude 


DE FR GB 


F-06800 Cagnes sur Mer (FR) 




• Foriel, Pierre-Andr6 


(71) Applicant: INTERNATIONAL BUSINESS 


F-06700 Saint Laurent du Var (FR) 


MACHINES CORPORATION 




Armonk, NY 10504 (US) 


(74) Representative: Scliuffenecker, Thierry 


Compagnie IBM France, 


(72) Inventors: 


D^partement de Propri^t6 Intellectuelle 


• Rchou, Aline 


06610 La Gaude(FR) 


F-06480 La Colle sur Loup (FR) 





(54) Method and system for adaptive bandwidth allocation in a high speed data network 



(57) This adaptive bandwidth allocation for Non- 
Reserved traffic over high speed transmission links of a 
digital network is operated through regulation of data 
packet transfers over network nodes/ports including 
input/output adapters connected through a switching 
device. 

To that end the network node is assigned with a 
Control Point computing devise (CP) storing a Topology 
Data Base keeping an image of the network 

This Data Base is periodically and at call set up 
updated by Topology Data Base Update messages 
(TDUs) including an Explicit Rate parameter for link I 
indicating the current available bandwidth on link I, and 
a parameter Nnri indicating the numt>€r of Non- 
Reserved connections on link I. 

These informations are used within each Adapter to 
periodically regulate the transmission bandwidth 
assigned to each Non-Reserved traffic connection 
within the network. To that end. each adapter is pro- 
vided with an Access Control Function device for each 
attached connection (data source) and a Connection 
Agent (CA) getting, on request, required cun-ent link 
informations from the attached Topology Data Base. 
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Description 

Field of the Invention 

5 This invention relates to a method and system for adaptively and dynamically operating bandwith allocation to so- 

called Non-Reserved Bandwidth traffic in a high speed<Jata transmission network. 

Background of the Invention 

10 Modern digital networks are made to operate in a multimedia environment for transporting different types of data 
(pure data or digitized information signals including voice, image, video, etc) over the same network, while ensuring the 
compliance with the requirements specific to each kind of these traffics. 

For instance, one may notice that the information provided by various users can be divided into different types. 
These include real-time information (such as voice information) that must be transmitted to the end-user with predefined 
15 limited time<ielay restrictions, and non-real-time information. If some real-time information is not transferred within said 
time delay it should sinnply be discarded. 

In this case, recovery of the original signal, at end-user location is made possible to some extent, by providing tech- 
niques such as interpolation/extrapolation techniques, in a data packet transmission environment These techniques do 
provide solutions to overcome the "loss" of only a limited number of discarded consecutive packets. They do not over- 
20 come the delay restriction requirement. 

On one hand the information may be considered as including : a so-called Reserved traffic information whose 
transmission must be guaranteed with predefined maximum delay according to conditions contractually agreed upon 
by both parties, i. e. end-user and network owner ; and a Non-Reserved (NR) information, such as certain control infor- 
mation or traffic of specific sources to be vehiculated over the network with no specific time constraint, but which traffic 
25 should be optimized for network efficiency. 

On the other hand, one should recall that different techniques have been developed, such as packet switching tech- 
niques, whereby the digitized data are arranged into so called bit packets as already mentionned. and circuit switching 
techniques. 

The basic advantage of packet switching techniques as compared to circuit switching techniques, is to allow a sta- 
30 tistical multiplexing of the different types of data over a line which optimizes the transmission bandwith. The drawback 
of packet switching techniques compared to circuit switching techniques, is that it introduces jitter and delay which, as 
already considered, may be detrimental for the ti-ansmission of isochronous data, like video or voice. This is why meth- 
ods have been proposed to control the network in such a way that delays and jitters are bounded for &/ery new connec- 
tion that is set-up across a packet switched network 
35 These methods have been described, for instance a co-pending European Application 94480097.8 . All these 
methods include, for any end user requesting service or any control data to be vehiculated over tiie network, establish- 
ing a path ttirough network high speed links (or lines) and nodes or ports, with optimal use of the available transmission 
bandwidth. 

Basically, one may allocate predefined bandwidths to Reserved traffic (including real-time) on the basis of contrac- 
40 tually defined parameters, and then allocate whatever left in the bandwidth to Non- Reserved traffic on fixed basis. 

But. bearing in mind that instantaneous traffics are eminentiy variable for botii Reserved and Non-Resented traf- 
fics, any fixed bandwidth assignment is naturally inefficient as far as the efficiency of global network utilization is con- 
cerned. 

A first improvement consists in preconputed oversized bandwidths allocations on a source by source basis, with 
45 the provision of means for detecting instantaneous congestions occurring within tiie network and for monitoring some 
sort of "slowing-down" mechanism. Such a mechanism has already been described in tiie above mentioned copending 
European Application as well as in US patent 5 280 470. In the mentioned co-pending application, ttie slowing-down 
mechanism is only used to control congestion at node switching level ttirough management of a switch back-pressure 
signal. In ttie US patent 5 280 470 slowing-down is operated over reserved bandwidths only when congestion is 
50 detected in network nodes and no increase is allowed, which may result in low link utilization in case of some sources 
being non-active. Accordingly the data sources are not really taken into account on a dynamic basis. In other words, 
the considered prior art system does not provide true dynamic sharing among connections but only helps resolving traf- 
fic congestions temporarily by sending a slow-down message back to sources. 

55 Objects of the Invention 

One object of this invention is to provide a method for optimizing bandwidth allocation to Non-Reserved traffic in a 
data communication network. 

Anottier object of the invention is to provide a mettiod for monitoring Reserved traffic and dynamically assigning or 
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adapting transmission bandwidth to Non-Reserved traffic accordingly in a data communication network. 

Still another object of the invention is to provide a method for dynamically and fairly distributing transmission band- 
width among Non-Reserved traffic sources, based on real data sources requirements, in a commemication network 
operating in Asynchronous Transfer Mode (ATM), or Frame relay. 

These and other objects, characteristics and advantages of the invention, shall be more readily apparent from the 
following description of a preferred embodiment made with reference to the accompanying drawings. 

Summary of the Invention 



This invention deals with an adaptive bandwidth allocation method for optimizing data traffic in a high speed data 
transmission network including Nodes interconnected by high speed links made for vehiculating data traffics of different 
priority levels along assigned network paths between data terminal equipments acting as data sources and data desti- 
nation terminals, said priority levels including high priority level(s) for so-called Reserved traffic for which a transmission 
bandwidth has been reserved along said assigned path based on predefined agreements, and low priority level for so- 
75 called Non-Reserved traffic which should be transferred over the network within the transmission bandwidth available 
along the considered path once Reserved traffic is satisfied, said method for assigning bandwidth to Non- Reserved traf- 
fic including : 

generating and keeping at least one Topology Data Base storing an image of the network occupancy over each link 
20 along the network paths; 

periodically and at any terminal call set-up within the network, generating and broadcasting Topology Data Base 
updating (TDUs) messages, said TDU messages including a so-called Explicit Rate parameter (ER|) for each link 
I indicating the bandwidth currently available on link I. and a parameter N^r indicating the number of Non-Reserved 
25 connections on link I; 

upon receving said TDUs information, computing for each node along the considered path the amount of transmis- 
sion bandwidth left available over each link along the considered path and assigning said available bandwidth to 
the Non- Reserved traffic sources connected to the network. 

30 . 

Brief Description of the Figures 

Figure 1 is a schematic representation of an example of data transmission network made to include the invention. 
35 Figure 2 is a schematic representation of the device made to implement the invention within one network node. 
Figure 3 is a detailed representation of the system made to implement the invention within one node adapter. 
Figure 4 is a schematic representation of a device to be used within the invention. 

40 

Rgure 5 is a detailed flow-chart made to implement the invention. 
Detailed Description of a Preferred Embodiment of the Invention 

45 While the invention applies equally to both centralized control networks and distrilxjted control networks, the pre- 
ferred embodiment shall herein be described with reference to a distributed control data transmission network. There- 
fore, in no instances shoukJ this be considered as implying any limitation to the invention. 

Accordingly, Rgure 1 shows an example of a packet switching network with distributed control, (i. e. control at each 
node of the network), which can be used to inplement the invention. This network includes five switching nodes SWO 

50 to SW4 interconnected by high speed trunk lines (or links) (10. 1 1 . 12, 13 et 14) arxl that can be accessed by access 
lines (AL's) connected to outside data terminal equipments (DTE's) acting as data sources or destination terminals. 

The network control architecture being a distributed one. each switching node is controlled by a control point CP. 
All CP*s are int^connected via a control poirtt spanning tree (CPST) which provides an efficient means for multicasting 
control messages between the control points. When a CP wants to broadcast a control message to other CP's in the 

55 network, it sends this message to the predefined CPST switching address, and the architecture provides the means to 
route this message on every line of the CP spanning tree, and only on these lines. This architecture also provides the 
means to initialize the tree address on each switching node, and to automatically reconfigure the tree in case of line or 
switching node failure. 

Each CP includes a copy of the Topology Data Base that contains the information about the network. It includes the 
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network physical configuration and the line characteristics and statuses. 

For every line I. in the network, vehiculating a so-called Reserved traffic, the maximum delay T(n) that can be 
accepted on a packet with a specified priority, and the level of bandwidth utilization R„res(n) on this lineare defined and 
recorded in the topology data base. This Information is distributed to other control points via topology data base update 
5 messages (TDUs) sent over the control point spanning tree whenever required. 

For more informations on such a Spanning Tree organization, one may refer to the Copending European Patent 
Application number 94480048.1. with the title "A Data Communication Network and Method for Operating said Net- 
work". _ 

In operation, any source user terminal equipment may request being connected to a destination terminal. For 
10 instance user terminal equipment DTE-A and DTE-B which are respectively connected to the network via access lines 
AL-A and AL-B. shall be interconnected thru the network with a given quality of service (QoS) specified in terms of a 
maximum delay T-max and a packet loss probability P-loss, upon DTE-A requesting being connected to DTE-B (i.e. at 
DTE-A call set-up) . 

To that end. at the switching node SWO. the control point CRD first uses the QoS and the traffic characteristics spec- 
is if led by the user (peak rate, mean rate, average packet length) to compute the amount of bandwidth C_eq. called the 
equivalent capacity of the connection to be reserved on every line, on the route or path assigned to the traffic between 
source terminal and destination terminal, in order to guarantee a packet loss probability PO(n) on this line which is 
smaller than the loss probability PJoss that has been specified for the connection. 

Based of the information that is available on a line basis in the topology data base, the control point CPO then com- 
20 putes the best route in the network to reach the destination. To that end. a Path Selection Program first identifies the 
network lines that are eligible for the route. If R(n) and R_res(n) respectively denote the capacity of line n and its curent 
Iwel of reservation, then the line is eligible if : 

R__res(n) + C_eq < 0.85 R(n) 

it then uses a modified Bellman-Ford algorithm to find the minimum weight, minimum hop count, route from the origin 
to the destination which uses eligible lines and which satisfies the QoS. 

T_max < 5:T(n) 

PJoss < 1-71 (1-PJ(n)) 



25 



30 



where the summation and product operators are carried over the N lines of the route (n=1 N). 

For additional information on equivalent capacity and best route considerations, one may refer to the following pub- 
35 lications : 

- R. Guerin. H. Ahmadi. M. Naghshineh. "Equivalent Capacity and its Application to Bandwidth Allocation in High 
Speed Networks", published in IEEE Journal of Selected Areas in Communications, JSAC-7. Sept. 1991. 

40 . H Ahmadi. J. S. Chen. R. Guerin. L GQn, A. M. Lee and T Tedijanto, "Dynamic Routing and Call Con\ro\ in High- 
Speed Integrated Network", pusblished in Proc. Workshop Sys. Eng. Traf. Eng.. ITC 13, pp 397-403. Copenhagen. 
Denmark. 

Now. let's assume that the chosen route to connect DTE-A1 to DTE-B from switching node SWO to switching node 
45 SW4 uses trunk lines 10. 11 and 14 via switching nodes SW1 and SW2 and access lines AL1 on switching nodes SWO 

and SW4. , i, • 

To that end. the origin control point CPO sends a connection set-up message along the route, a copy of which is 
delivered to the control point of every switch on the route (e. g. CP1 . CP2 and CP4). This message contains a list of the 
network addresses of the control points on the route, the list of the link names (e. g. 10. 1 1 . 1 4) between these control 
50 points, the request bandwidth C_eq. the priority of the connection, and a connection correlator C_cor which is set by 
the origin control point CPO and which is used by all other CP's to uniquely identify the connection. 
Upon reception of the copy of the set-up message, each CP performs two basic tasks. 

First, the CP checks whether the equivalent capacity of the new connection is still available oh the line to the next 
switching node on the route, and if it is available, it reserves it. Therefore, the CP checks whether the line is eligible by 
55 verifying the first above relation. If it is, the CP reserves the desired amount of Ijandwidth on the transmit line for the 
new connection, accepts the connection set-up, increments the reservation level : 

R_res(n) = R_res(n) + C_eq 
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and if this reservation level has significantly changed, it eventually broadcasts a topology data update (TDU) message 
on the CP spanning tree to inform the other CP*s of the new reservation level R_res of this particular line. 

Second, the CP allocates a new label for the new connnection. and sends back this label to the^ntrol point of the 
previous switch on the route, for label swapping purposes. 

5 Accordingly, during network operation, each node n (n=0. 1 ,...) Control Point (CPn) periodically, and at call set-ups. 

broadcasts Topology Data-Bases Updating (TDUs) messages collected by access nodes. Now, for the purpose of the 
dynamically adaptive control of the network bandwidth allocation of this invention, the TDU format shall be made to 
include a so-called Explicit Rate (ER) parameter. Accordingly, as represented in Figure 1 . the TDU format for any link I 
shall include, in the above mentioned TDU messages, the Explicit Rate for link I (i. e. ERI) which ERI shall specify the 

10 current available bandwidth on the link I divided by the number of NR connections, and therefore indicate dynamically 
said available bandwidth to the corresponding Control Points. This information shall enable adaptively assigning band- 
width to sources requesting service for transmitting the so-called Non-Reserved (NR) traffic, with a full knowledge of 
the bandwidth currently available on all considered links. 

Assuming the traffic to be vehiculated from source terminal DTE-A1 to destination terminal DTE-B, through the 

75 above mentioned path SWO, 10, SW1. 11. SW2, 14, SW4. then each of these node Topology Data Bases shall have 
available the Explicit Rates on the node connected trunks. 

In addition, the TDU format over link I shall also include an indication of number of Non-Reserved connections on 
said link I. (i. e. : N^ri). 

Given these pieces of informations, not only the access node (SWO) Control Point is made capable of defining 

20 whether Non- Reserved traffic from DTE_A may be sent over the network, but in addition the network organization 
makes it possible to fairly and dynamically adjust the bandwidths distributed among the link connected Non-Reserved 
sources in order to mimize the data packets lost, without impacting on Reserved traffic. 

Represented in figure 2 is a block diagram showing the various devices used within any given node, e. g. Node zero 
including a switching device SWO and attached Control point device CPO. The switching device SWO includes several 

25 adapters each being connected to one line or link said adapters are labelled Adapter 0, Adapter 1 , .... Adapter n. One 
line may handle up to thousands of connections to traffic sources. For example, traffic sources labelled 21, 22. 23 are 
represented attached to Adapter 0. 

The data traffic of each source is oriented toward an Access Control Function device (see 24. 25, 26). Said Access 
Control Function devices are attached to an Adapter Control Agent (CA) in both directions. Each Control Agent (CAO, 

30 CA1. ... CAn) is attached to the node Control Point (CPO) to get. on request, link information for local connections 
attached, from the corresponding Topology Data Base. Also, as already mentioned, the CPO Topology Data Base gets 
the Topology Data Update (TDU) messages (e.g. TDU 11. TDU 12...) from the network links (see figure 1). 

Represented in figure 3 is an illustration of the operation of an Access Control Function (ACF) device 30 and a Con- 
nection Agent (CA) Device 31 . To understand the operation of this system, one should first remember that the data traf- 

35 f ic from any user is organized into packets (or ATM cells herein considered as packets) the transmission of which, over 
a node output line, is regulated. Various regulating methods are known in the art. One of these methods utilizes a so- 
called Leaky Bucket mechanism. A leaky bucket mechanism is illustraed in figure 4. Basically in the mechanism shown 
in figure 4, the data packets to be transferred are first passed through an admission buffer or shift register arrangement 
41 . The transfer from admission buffer to the network line is regulated by a token pool. To that end, a "token** generator 

40 is made to generate tokens at a predefined rate and said tokens are stored into a token pool 42. Then, each data packet 
to be transferred from the admission buffer 41 , to the network, shall request as many tokens as the data packet contains 
bytes . Should these tokens be available in the token pool 42, the considered data packet shall be passed to the net- 
work. Otherwise the data packet should wait until the number of tokens has been generated. Since the tokens shall be 
individually attached to the requesting data packets, the mechanism may be improved to enable discriminating among 

45 discardable and non discardable data. Therefore, at the leaky bucket level, processing discrimination between discard- 
able packets and non-discardable packets shall be performed through duplication of the token pool. To illustrate this, 
non-discardable packets shall have been tagged with a so-called green tag and discardable packets shall have been 
tagged with a so-called red tag. Accordingly two token pools are then used, one for "green** tokens and one for "red" 
tokens. Both pools are fed-in independently from each other. The green token pool is fed with a token rate C_eq^^ equal 

50 to the equivalent capacity that has been reserved for the connection k in the network, or with a token rate MCRk which 
is the minimum guarateed bandwidth for NR. The red token pool is fed with a token rate R^ j. While the computation of 
C_eq is described in the above mentioned references, the adaptive computation of the Rk,t ^ an object of the present 
invention. 

For instance, discardable data packets may include voice data packets recoverable at receiving end through sev- 
55 era! known mechanisms, e. g. interpolation/extrapolation mechanisms. But what is more important for the present 
invention is that the data packets transfers through the leaky bucket mechanism may be regulated by controlling the 
token generation rates. This is why, turning t>ack to figure 3. one may notice that the Leaky Bucket 32 of the Access 
Control Function device (24) for a data source k is attached to a variable rate token pool 33. Said token pool 33 is also 
provided with threshold reference indications (a low threshold reference THl and a high treshold reference THh) to be 
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10 



15 



20 



used for regulation purposes. The token pool level with respect to these thresholds shall indicate the -"^as^re o^ irt 
S^aTdXe whether the token generation rate should be increased, decreased or kept even (,. e. not changed) 
^or tery connection along the considered path the token generation rate R,, is updated by a 
instanceTI roken Rate computing mechanism 31 for connection k. shall update the token generation at t.rne ^^^^^^^ 
nn pn u«latS token generation rate Rk This is made possible first through the use of a parameter measuring the 
uS S o?fc^mSon k (Se 35) morTiiored by the token pool 33 and indicating whether the token f^nera^^r^e 
S be inc^easS! decreased or not changed, for instance, based on monitoring the token pool le.el with reference 

'° ""^le llSolmations provided by all the token utilization devices, such as 35. attach«J to ^^'^^'"f i^"^' ^""^^ 

tions^f the Accis Co'ntrol Funcfion device 30 attached to the consklered access Hnk are fed 

width comouting device 36 within the Connection Agent device 31. This computing device 36 ke^ tracking me 

SSwSrcurnfly alLated to each connection k of the considered port. The computing dev.^36. m turn, dr ves a 

Se upSlgrllL 37 controlling the token rate device 34. The computing device ^PJ^^^^^^^ 

al reaiHred Explicit Rates (ER^ and numbers of Non-Reserved connections (Nnr,) availaWe .n the Tof»'09yDate Base 

as 2dat«l bTtSe various t6u,) fed into the considered node Control Point (e. g. CPO) to enable <^^''Q^l 

u^aS t^ken generation rate R^:, to be assigned to the connection k ou link 1 at time t. and then dnve the token rate 

''ToperaL. the system gets periodically leaky bucket mea^^^^^ 

tft hp increased m decreased (d), or kept even (i. e. unchanged) (e). ^^u^ith/^ 
to t^rpath of connection k To determine the rate allowed to the connection k of the 

of the port, for every link I belonging to U along their path. B, t is given by : 



25 



30 



B,t = ER,xN, 

(1-(Rho)^"%,)CI- 5:MCRk 

Ji^J N, 



Nnri 



wherein : 

35 H\ 

ER, is the explicit rate for link I ; 



is the number of Non-Reserved connections attached to the local port that have link I in their path 



(Rhor^,t 



40 



45 



is the bandwidth ratio used by reserved traffic on link I at time t. statistically monitored on ttie network 

nodes considered. 



C, is the link I speed ; 

is the total number of Non-Reserved connections within the network that have link I on their path. 



Nnri 
MCRk 



is the fraction of bandwidth "reserved" for Non Reserved traffic of connection k. (Eventhough this 
iramI;?ScRK should be null for Non-Reserved traffic, one may optionally reserve a fa.r m.n.mum 
bandwidth anyway, for that traffic). In other words 



50 MR 

^ MCR k would be the sum of the Minimum Cell Rates 

k= 1 



55 



would be the sum of the Minimum Cell Rates (MCR) (if any) of all Non-Reserved connections sharing 
link L 

Then, using the leaky bucket measurements for the local node at time t - 1. the new explicit rates R^, for sources 
attached to this node should be computed for time t. 
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Using informations from the leaky bucket, the system can deduce the number N^'^, ^ of connections bottlenecked 
asking for more bandwidth. N^^^^ t ^^^^ connections which do not use all their bandwidth and therefore can release some 
of it. N^®\t oi connections which use the bandwidth they need and do not need more (N ,=N , t+N-^^ t+N , t) - Note 
that this classification based on whether the rate of connection k should be increased, decreased or unchanged only 
5 depends on the current value set at the local node. t-i 

For a given connection k. we will use the current rate R|,k,M set on link I at time t-1 and re-write R) k \.^ as ^ t-i 
If connection k needs a decrease. R^'Vk,t-i connection k needs an increase and R^®Vk,M connection k can be held 
to its current rate. The computation of the rates R| k t 's done according to the following recurrent system on every link I 
of ^ : 

10 

0 if decrease. 

R _ rR(d) , 1 

15 

0 if no change, 

^ I t (6) 

20 f^l.k.t = l.k.M -^^l.t+P'l.tl 



0 if increase. 

25 



N(i) 



1, t 



30 



Bl,t-1 nTTT 



35 

where a\t and a"i t are multiplicative decrease factors and p'l t and p"| , are additive increase factors. 
The rate of connection k is then set to the minimum rate computed along its path : 

40 Rk, t = (Rl,k,t} 



and then. 

45 

R ,^ t := max {MCR j^, min {PGR R ^^]] 

The underlying assumption for this model is that all connections should be able to release at any time the band- 
width they got in order to satisfy a defined fairness criterion. For instance, if at an arbitrary time there are only connec- 

50 tions which ask for an increase and connections which are "ok", it is not fair that this state for the previous system be 
staWe : some of the bandwidth allocated to the connections "ok" should be re-distributed among the bottlenecked con- 
nections. The fairness criterion chosen here means that a state where all connections need more k^andwidth tiian the 
network can offer is a more fair state than the unbalanced state mentioned here above. This is, naturally, but one of the 
fairness criterion which could be used. 

55 The sum term in the equation for connections which need more barxlwidth is also used to achieve some fairness 
among them. Without this term (i. e., sinnply using R^*^!^ m)* connections which already have a significant amount of the 
total bandwidth arxJ ask for more will never release part of what they got in favor of connections with small rates which 
suddendly ask for bandwidth. As this scenario is not fair, the global t^andwidth of connections waiting for an inaease 
shouW be equally redistritHrted (according to the max-min criterion). 
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At last, the term B,,,/B,.t.i equally distributes over all connections the variations of the available bandwidth for non 
reserved traffic on link I. x 

The problem for confuting a, a", „ p', , and p",,, is not simple, as they are function of one or more of the time var- 
iables N«, N(^),,„ N(«),.,. As a consequence, they are themselves function of time. Moreover, these parameters should 
5 always satisfy, for link I. that 

N, N, 

ZF'l.j.t = ^lVBl.M'«Zf'u.M 
j=1 J=1 

10 

The resolution of the system being too complex to be evaluated for each time t. an heuristic approach should be 

employed : 

15 0 For connections which Should decrease, a, t is of course . o ^«<th^ 

less than one and should be closer to 0 as the number of connections which need bandwidth ,s high. Some of the 
bandwidth released should also be added to connections which need no change, i. e.. is part of the p ,.t term, we 
set : 



20 



25 



30 



^!t = l 5 2 

0 For connections which should need equal bandwidth, a",,, should also be closer to 0 as the number of connec- 
tions which need bandwidth is high. 

On the other hand, the rate of these connections grows up by applying N«„ on connections which release 

bandwidth. 

35 This amount is equally distributed over the connections ; 
this gives : 

„. I , (d) (3) 

40 N , j^l 

0 For connections which should increase, the term p",., is the total bandwidth released by applying the term 
N«2, ,/n2, on both previous sets of connection rates, equally distributed over the Vi connections : 



45 



^' j = l 3 = 1 



50 



55 



The algorithm used to implement the invention may be summarized as follows : 
For all connections : 
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0 using the leaky bucket statistics, "mark" connection k as requiring an increase, decrease, or no change. 
For all links : 
5 0 Compute and N^^), t 

0 Upon reception of a TDU message, update the available bandwidth available on each link I: 



10 



15 



20 



30 



40 



45 



SO 
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N 



NRI 



(1 -{Rho)^^%,)C,- X^CRk 



B,, = ER, X N, = ^ N, (5) 

N«^>,, Nt*),, N<^>,, 



0 Compute X R' ^j.M. Zf^''.J.Mand ^ ^j.m 
j-1 i=i j=i 



For all connections : 

0 For all links in connection path, update Ri k,t 
25 • if decrease. 



(02 m(0 M(e) 



if no change. 



0)2 Kj(i) n"",., 



35 R _^it^_rR(e) /1 . Mx.- if V R 1 m 



if increase, 



Ri,k,t = — C , ■ , 2: R(i)i,j,t-i+ C ER(<3)i j 

Bl,t-1 NU)i t j = l N^i 3 = 1 

+ E ' R(e)i t-l ) 3 (8) 
3 = 1 



0 and set 



Rk,t = rain {Rl,k,t) (9) 
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Rf^ ( = max{MCR(^. minlPCRj,, R^j}} (10) 

5 In practice, it is expected that the non-reserved traffic will be mostly bursty with long idle periods. Because of these 

silent phases, it is reasonable to think that only a few connections will be active and then performances would be 
increased by introducing some statistical multiplexing. Basically, this means that we could allocate to every connection 
a "little bit more" than its rough fair share, as long as there is no congestion within the network. 

Represented in figure 5 is a block diagram of the algorithm for implementing the invention and getting the rate 
10 adjusment looked for, for a connection k 

First, a measure of utilization as defined by device 35 (see figure 3), as well as the measures of utilization of all 
other local connections (1 , 2. 3, ...k-1) is provided to a computing stage 50. Said computing stage also gets the rates at 
t-1 from a TABLE stored in the Connection Agent (CA) considered. Said table looks as follows : 

15 

TABLE 





llnki 


link 2 


" : linki 


Connection 1 






" : R|,1,t-1 


Connection 2 
















Connection k 









25 

The computing stage 50 (see figure 5) provides then N^'^n, H^^\ t ^^^\,x- 

These informations, together with the data provided by the above TABLE are then passed through a second com- 
puting stage 51, wherein the parameters a'l t. a"i t. P'l.t ^^d p\x are computed according to the above mentioned equa- 
30 tions 1 through 4, respectively. 

Finally, the a and p parameters, are fed into a third computing stage 52. together with the Explicit Rates for link I 
and the number of Non-Reserved traffics Nnr,. to enable computing the updated available bandwidth B, t according to 
equation 5. 

The above computing operations of stages 50, 51 and 52 are performed for every link I. 
35 Then, for every connection along the considered path, and depending whether the state of the connection as 
defined by the measure of utilization is: decrease, no change, (i. e. keep even), or increase, then the link rate is updated 
according to equations 6, 7 or 8 respectively, as indicated in stages 53. 54 and 55 of figure 5 (and device 37 in figure 3). 

Finally, the new token rate for link k (see device 34 in figure 3). is computed in stage 56 through computation of 
equations (9) and (10). 

40 This new token generation rate R^ i is then applied to update the token generation rate for the token pool 33 (see 
figure 3). 

Clainns 

45 1. An adaptive bandwidth allocation method for optimizing data traffic in a high speed data transmission network 
including Nodes interconnected by high speed links made for vehiculating data traffics of different priority levels 
along assigned network paths between data terminal equipments acting as data sources and data destination ter- 
minals, said priority levels including high priority level(s) for so-called Reserved traffic for which a transmission 
bandwidth has been reserved along said path based on predefined agreements, and low priority level for so-called 

so Non-Reserved traffic which should be transferred over the network with the transmission bandwidth available along 
the considered path once Reserved traffic is satisfied, said method for assigning bandwidth to Non-Reserved traffic 
including : 

generating at least one Topology Data Base storing image of the network occupancy over each link along the 
55 network paths; 

periodically and at any terminal call set-up within the network, generating and broadcasting Topology Data 
Base updating (TDUs) messages and storing in said at least one Topology Data Base said TDUs. said TDU 
messages including a so-called Explicit Rate parameter (ERi) for each link I indicating the bandwidth currently 
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available on link I, and a parameter N^r indicating the number of Non-Reserved connections on link I; 

upon receiving said TDUs information, computing for each node along the considered-path the amount of 
transmission bandwidth left available over each link along the considered path and assigning said available 
5 bandwidth to the Non- Reserved traffic sources connected to the network. 

2. A adaptive bandwidth allocation method according to claim 1 wherein said transmission network is a distritxjted 
control network said Topology Data Base being stored into each network node and said TDUs being broadcasted 
to said nodes along the considered path, said bandwidth available for Non-Reserved traffic being computed and 

10 assigned to concerned links within each node along the path. 

3. An adaptive bandwidth allocation method according to claims 1 or 2 including the following steps : 

a - for all connections k over a link I. mark periodically and at any connection set-up, the connections as requir- 
es ing an increased (i) bandwidth or a decreased (d) bandwidth, or no change (e) ; 

b - for all links I attached to a node along the considered path 

compute the number of connections requesting more bandwidth (N| the number of connections requir- 
20 ing less bandwidth (N| /*^^) and the number of connections owning the amount of bandwidth they need 

(N,,t^">): 

upon reception of a TDU message, update the available bandwidth : 



^5 Nnri 

(1 -(Rho),/'^)C,- X'^GRk 
M.t= N 



30 



35 



40 



55 



Bm = n N. 



'NRI 

wherein 

N, is the number of Non-Reserved connections attached to the local ports that have link I in their 

path ; 

(Rho)*^®®! t is the t^andwidth ratio for reserved traffic on link I at time t, statistically monitored on the network 
nodes considered. 

C| is the link I speed ; 

Nmri is the total number of Non-Reserved connections within the network that have link I on their 

path. 

MCRk Is the fraction of bandwidth "reserved" for Non Reserved traffic of connection k. (Everrthough 

45 this parameter MCR^ should be null for Non-Reserved traffic, one may optionally reserve a fair 

minimum bandwidth anyway, for that traffic). In other words 

Nnr 

V MCR would be the sum of the Minimum Cell Rates 

Compute 



i.t i.t 

Z f^^*^l.i.M* Z f^^*^ IJ.M 
i=1 i=1 
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Z " IJ.M 
j=1 



c - for all connections and for all links in connection path update R| k t as follows 
if decrease required : 



75 - if no change required 



20 



25 



30 



R m(*)2 K,(i) N**i.t 



if increase required : 

-»-#^ 



35 and finally setting t = min { R| ^ t } 

4. A system for dynamically adapting transmission bandwidth allocation to data traffic over a high speed transmission 
network including switching nodes (SWO, SW1 ....) attached to at least one Control Point processing unit keeping at 
least one updated Topology Data Base representing an instaneous image of the network, said switching nodes 

40 being interconnected by high speed links (10, 11...) for vehiculating data traffic of different priority levels along 
assigned network paths between network connected data sources and destination terminals, said priority levels 
including a high priority level for so-called Reserved traffic for which a transmission bandwidth is reserved in each 
link along the path based on predefined conditions, and a low priority level for so-called Non-Reserved traffic which 
should be transfered over the network within the transmission bandwidth left available along the considered path 

45 once Reserved traffic is optimized, said system for dynamically assigning transmission bandwidth to Non-Reserved 
traffic including : 

an Access Control Function device including Access Control means (24) connected to each data traffic source 
(k) attached to the considered link "I" for monitoring the source traffic and measuring current utilization from 
50 said connection k; 

a Connection Agerrt (CA) (31) connected to each Control Function device of a data traffic source attached to a 
same link T; 

55 ' means for attaching said Control Agent device to said at least one Topology Data Base to get. therefrom, link 
informations on request ; 

first computing means (36) within said Connection Agent device for computing the portion of line bandwidth 
B| t-i currently allocated to each connection k on the considered link I ; 
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second computing (37. 34) for computing an updated rate t assignable to each Non- Reserved traffic source 
of each connection k attached to link I. through said Access Control Function means (24). 

A system for dynamically adapting transmission bandwidth allocation according to claim 3 in a distributed network 
system wherin each network node is assigned a Control Point device (CP) storing said Topology Data Base, said 
system being provide with means for broadcasting Topology Data base Updating messages (TDUs) including, for 
each considered link I. a so-called Explicit Rate (ERI) parameter indicating the current available bandwidth on link 
I, and a parameter N^r indicating the number of Non-Reserved connections currently attached to said link I. 



w 6. A system for dynamically adapting transmission bandwidth allocation, as claimed in claims 4 or 5 wherein said 
Control Function means (24) includes : 

a leaky bucket (32) connected to each data source connection k for receiving data packets therefrom and to be 
passed to next link on the considered path upon collecting a so-called token from a token pool (33) filled in at 
75 a token generation rate R^ j ; 

means (35) for periodically monitoring the token pool (33) content with respect to predefined threshold levels 
and for measuring the considered connection k requirements based on the token pool level with respect to said 
thresholds. 

20 

7. A system for dynamically adapting transmission bandwidth allocation as claimed in claim 6, wherein said token pool 
is duplicated to enable distinguishing between Reserved traffic and Non-Reserved traffic. 



8. A system for dynamically adapting transmission bandwidth allocation according anyone of claims 6 or 7 wherein 
25 said means (35) for measuring each connection utilization periodically, monitors the corresponding token pool level 
of filling with respect to a so-called low threshold (THJ and a so-called high threshold (THh) and generate accord- 
ingly an indication meaning whether the token pool filling rate should be iricreased (i), decreased (d), or not 
changed (e). 



30 9. A system for dynamically adapting transmission bandwidth allocation as claimed in claim 8, wherein said Control 
Agent device (31) includes : 

means (36) for measuring the portion Bi t of bandwidth allocated to all the connections for every link I, 

35 B,, = ER,xN, 

wherein = ER| is the Explicit Rate for link I 

N| is the number of Non-Reserved connections attached to the nodes that have link I on their 
path, 

40 

rate updating means (37) connected to said B| j measuring means (36) and to said measure of utilization 
means (35) for computing the rate to be assigned to packet transfers on every connection k over link I at time 
t. based on previoi^ value (R|^t-i) a* time t-1 and increase/decrease/no change indications provided by means 
(35) 

45 whereby : 

for decrease : 

R - ^'^ rR(^ „• 1 

"l.k.t - R I" l.k.t-1-^ l.tJ 

° l.t-1 

50 for no change : 



R. 



B 



*l.k.t = f^^^^ l.k.M-^ 'l.t+P'l.tl 

for increase : 



55 
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^1, t-l Nt^^x t 

3 = 1 



10 

wherein : a* and a" are predefined multiplicative decrease factors 
and p" are predefined additive increase factors, 

wherein the indexes (d), (e), (i) respectively identify the connections that can release some of their bandwidths. 
those which own the bandwidth they need, and those asking for more bandwidth as indicated by devise (35) ; 

- means (34) for setting the updated token generation rate for connection k to the minimum rate along its path : 

Rk,t = min{R,j,^} 

10. A system for dynamically adapting transmission bandwidth allocation as claimed in claim 9. Wherein the minimum 
fraction of bandwidth MCRk reserved for Non-Reserved connection is made equal to zero. 

25 11 . A system for dynamically adapting transmission bandwidth allocation as claimed In claim 9 wherein R. , is bound 
by MCRk anci PCRk. with : 

R ^ ^ = max {MCR min {PGR k, R ^ j.^ }} 

30 12. A system for dynamically adapting transmission bandwidth allocation as claimed in anyone of claims 9 10 or 11 
wherein: 

N«%, N^,N<-)■.t 
a",. = 1- 



20 



40 



*^ l.t - 2 2-r " IJ.M 
I j=1 



45 



50 



55 
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